

# **Max FIFO**Application Note



## Application Note - Max FIFO

Document revision 1.0

Document release date February 2021

Document number BST-BMI270-AN001-01

Document valid for 0 273 017 008

Notes Data and descriptions in this document are subject to change without

notice. Product photos and pictures are for illustration purposes only

and may differ from the real product appearance

## **Index of Contents**

| 1. | Intro | ductionduction                                 | 6          |
|----|-------|------------------------------------------------|------------|
|    | 1.1.  | Max FIFO                                       | .6         |
| 2. | Quic  | k Start Guide                                  | 7          |
|    | 2.1.  | Note about using BMI270                        | .7         |
|    | 2.2.  | First application setup examples algorithms:   | .7         |
| 3. | Func  | tional Description1                            | l1         |
|    | 3.1.  | System Configurations                          | 11         |
|    | 3.2.  | Block Diagram                                  | 11         |
|    | 3.3.  | Power-On-Reset (POR) and Device Initialization | 12         |
|    | 3.4.  | FIFO                                           | 13         |
|    | 3.5.  | General Interrupt Pin Configuration            | 14         |
|    |       | Electrical Interrupt Pin Behavior1             | <b>L</b> 4 |
|    |       | Interrupt Pin Mapping1                         | 4          |
| 4. | Regi  | ster Description                               | L5         |
|    | 4.1.  | General Remarks                                | 15         |
|    | 4.2.  | Register Map                                   | 16         |
|    |       | Register (0x00) CHIP_ID2                       | 20         |
|    |       | Register (0x02) ERR_REG2                       | 20         |
|    |       | Register (0x03) STATUS2                        | 21         |
|    |       | Register (0x04) DATA_02                        | 21         |
|    |       | Register (0x05) DATA_12                        | 22         |
|    |       | Register (0x06) DATA_22                        | 22         |
|    |       | Register (0x07) DATA_32                        | 22         |
|    |       | Register (0x08) DATA_42                        | <u>2</u> 3 |
|    |       | Register (0x09) DATA_52                        | <u>2</u> 3 |
|    |       | Register (0x0A) DATA_62                        | 23         |
|    |       | Register (0x0B) DATA_72                        | 24         |

| Register (0x0C) DATA_8          | 24 |
|---------------------------------|----|
| Register (0x0D) DATA_9          | 24 |
| Register (0x0E) DATA_10         | 24 |
| Register (0x0F) DATA_11         | 25 |
| Register (0x10) DATA_12         | 25 |
| Register (0x11) DATA_13         | 25 |
| Register (0x12) DATA_14         | 25 |
| Register (0x13) DATA_15         | 26 |
| Register (0x14) DATA_16         | 26 |
| Register (0x15) DATA_17         | 26 |
| Register (0x16) DATA_18         | 26 |
| Register (0x17) DATA_19         | 27 |
| Register (0x18) SENSORTIME_0    | 27 |
| Register (0x19) SENSORTIME_1    | 27 |
| Register (0x1A) SENSORTIME_2    | 28 |
| Register (0x1B) EVENT           | 28 |
| Register (0x1C) INT_STATUS_0    | 29 |
| Register (0x1D) INT_STATUS_1    | 29 |
| Register (0x1E) GYR_CAS         | 29 |
| Register (0x1F) Reserved        | 30 |
| Register (0x20) Reserved        | 30 |
| Register (0x21) INTERNAL_STATUS | 31 |
| Register (0x22) TEMPERATURE_0   | 32 |
| Register (0x23) TEMPERATURE_1   | 32 |
| Register (0x24) FIFO_LENGTH_0   | 33 |
| Register (0x25) FIFO_LENGTH_1   | 33 |
| Register (0x26) FIFO_DATA       | 33 |
| Register (0x40) ACC_CONF        | 34 |
| Register (0x41) ACC_RANGE       | 35 |
| Register (0x42) GYR_CONF        | 36 |
| Register (0x43) GYR_RANGE       | 37 |
| Register (0x44) AUX_CONF        | 38 |

| Register (0x45) FIFO_DOWNS         | 39 |
|------------------------------------|----|
| Register (0x46) FIFO_WTM_0         | 39 |
| Register (0x47) FIFO_WTM_1         | 40 |
| Register (0x48) FIFO_CONFIG_0      | 40 |
| Register (0x49) FIFO_CONFIG_1      | 41 |
| Register (0x4A) SATURATION         | 42 |
| Register (0x4B) AUX_DEV_ID         | 42 |
| Register (0x4C) AUX_IF_CONF        | 43 |
| Register (0x4D) AUX_RD_ADDR        | 43 |
| Register (0x4E) AUX_WR_ADDR        | 44 |
| Register (0x4F) AUX_WR_DATA        | 44 |
| Register (0x52) ERR_REG_MSK        | 44 |
| Register (0x53) INT1_IO_CTRL       | 45 |
| Register (0x54) INT2_IO_CTRL       | 46 |
| Register (0x55) INT_LATCH          | 46 |
| Register (0x56) INT1_MAP_FEAT      | 46 |
| Register (0x57) INT2_MAP_FEAT      | 47 |
| Register (0x58) INT_MAP_DATA       | 47 |
| Register (0x59) INIT_CTRL          | 47 |
| Register (0x5B) INIT_ADDR_0        | 48 |
| Register (0x5C) INIT_ADDR_1        | 48 |
| Register (0x5E) INIT_DATA          | 48 |
| Register (0x5F) INTERNAL_ERROR     | 49 |
| Register (0x68) AUX_IF_TRIM        | 49 |
| Register (0x6A) NVM_CONF           | 49 |
| Register (0x6B) IF_CONF            | 50 |
| Register (0x6C) DRV                | 50 |
| Register (0x6D) ACC_SELF_TEST      | 51 |
| Register (0x6E) GYR_SELF_TEST_AXES | 51 |
| Register (0x70) NV_CONF            | 52 |
| Register (0x71) OFFSET_0           | 52 |
| Register (0x72) OFFSET_1           | 53 |

|    | Register (0x73) OFFSET_2            | 53 |
|----|-------------------------------------|----|
|    | Register (0x74) OFFSET_3            | 53 |
|    | Register (0x75) OFFSET_4            | 53 |
|    | Register (0x76) OFFSET_5            | 54 |
|    | Register (0x77) OFFSET_6            | 54 |
|    | Register (0x7C) PWR_CONF            | 55 |
|    | Register (0x7D) PWR_CTRL            | 56 |
|    | Register (0x7E) CMD                 | 56 |
|    |                                     |    |
| 5. | Legal disclaimer                    | 57 |
|    | 5.1. Engineering samples            | 57 |
|    | 5.2. Product use                    | 57 |
|    | 5.3. Application examples and hints | 57 |
| 6. | Document History and Modification   | 58 |

#### 1. Introduction

BMI270 is an ultra-low power IMU optimized for wearable applications. The IMU combines precise acceleration and angular rate measurement with intelligent on-chip motion-triggered interrupt features. The 6-axis sensor combines a 16-bit triaxial gyroscope and a 16-bit triaxial accelerometer in a compact  $2.5 \times 3.0 \times 0.8 \text{ mm}$ 3 LGA package

BMI270 is a member of Bosch Sensortec's BMI260 family of IMUs, targeting fast and accurate inertial sensing in wearable applications. BMI270 features Bosch's automotive-proven gyroscope technology with an improved accelerometer. Significant improvements in BMI270 include, but are not restricted to, the overall accelerometer performance, i.e. an extremely low zero-*g* offset and sensitivity error, low temperature drifts, robustness over PCB strain and a low noise density.

BMI270 features the industry's first self-calibrating gyroscope using motionless CRT (Component Re-Trimming) functionality to compensate MEMS typical soldering drifts, ensuring post-soldering sensitivity errors down to  $\pm$  0.4%.

BMI270 includes intuitive gesture, context and activity recognition with an integrated plug-and-play step counter/detector, which is optimized for accurate step counting in wrist-worn devices. The IMU is also well suited for other types of wearable devices, such as hearables, smart clothes, smart shoes, smart glasses and ankle bands.

BMI270 is available in application-specific versions: gesture and context & activity. The 'gesture' version includes flick in/out, arm up/down, and wrist tilt features. The 'context and activity' version has advanced features for recognizing context activity and activity change, for example standing, walking and log car parking by detecting the activity change.

In case none of the features are needed but FIFO size is critical, there is a Max FIFO configuration.

#### 1.1. Max FIFO

This application note describes the Maximum FIFO configuration of BMI270 that offers 6 KB of FIFO. Users benefit from system-level power savings as the host ( $\mu$ C) does not need to be awake all the time.

For complete details regarding BMI270 specifications (e.g. pin-out, power modes, self-test, temperature sensor, Sensor Time, FIFO), Digital interfaces (primary/secondary), landing pattern, HSMI and sensor API refer the following:

https://www.bosch-sensortec.com/products/motion-sensors/imus/bmi270.html

https://www.bosch-sensortec.com/media/boschsensortec/downloads/datasheets/bst-bmi270-ds000.pdf

https://github.com/BoschSensortec/BMI270-Sensor-API

#### 2. Quick Start Guide

The purpose of this section is to help developers who want to start working with BMI270 by giving some basic hands-on application examples to get started.

#### 2.1. Note about using BMI270

The communication between application processor and BMI270 will happen either over I2C or SPI interface.

Each register read operation includes dummy bytes:

- I2C: 0
- SPI: 1

For simplicity the dummy bytes are not shown in the examples below.

Before starting the test, BMI270 has to be properly connected to the master (AP) and powered up. The device is configured for advance power save mode after POR or soft reset. For details on the interface operation in advanced power save mode, see the description of Register <a href="PWR">PWR</a> CONF.adv power save For more information about the interfaces, see BMI270 data sheet

#### 2.2. First application setup examples algorithms:

After correct power up by setting the correct voltage to the appropriate external pins, BMI270 enters automatically into the Power On Reset (POR) sequence. In order to properly use BMI270, certain steps from host processor front are needed. The most typical operations will be explained in the following application examples in form of flow diagrams.

#### 1. Testing communication and initializing BMI270

a. Reading chip id <a href="CHIP\_ID">CHIP\_ID</a> (0x24) (checking correct communication). The interface is coming up configured for I2C, the initial dummy read configures it to SPI.



#### b. Performing initialization sequence<sup>1</sup>



Modifications reserved | Data subject to change without notice

 $<sup>^{1} \</sup> The \ bmi270\_config\_file \ in \ https://github.com/BoschSensortec/BMI270-Sensor-API/blob/master/bmi270\_maximum\_fifo.c$ 

## c. Checking the correct initialization status



Note: To configure BMI270 in Low-power mode / Normal mode / Performance mode refer BMI270 data sheet

## 3. Functional Description

#### 3.1. System Configurations

BMI270 has 14 external I/F pins and supports the SPI and I2C protocols on its primary interface to the host system. BMI270 supports on its secondary interface (I2C master) an auxiliary sensor configuration (e.g. a magnetometer) configuration. Both configurations work independent of the configuration (SPI/I2C) of the primary interface. If the secondary I/F is configured as AUX I/F, the sensor data of the IMU and the AUX sensor are synchronized.



#### 3.2. Block Diagram

#### BMI270



For details regarding Supply Voltage, see BMI270 data sheet

#### 3.3. Power-On-Reset (POR) and Device Initialization

During POR the voltages VDD/VDDIO are ramped to their respective target values. After reaching the target supply voltages, all registers are accessible after a delay of  $450 \mu s$ .

After every POR or soft reset, the IMU remains in suspend mode. To get ready for operation the device must be initialized through the following procedure:

- Disable advanced power save mode: PWR\_CONF.adv\_power\_save =0b0
- Wait for 450 μs (or 12 LSB of SENSORTIME 0)
- Write INIT\_CTRL.init\_ctrl = 0x00 to prepare config load
- Upload configuration file
  - Burst write 328 Bytes of initialization data to Register <u>INIT\_DATA</u> (start with byte 0 of initialization data)
  - The configuration file for Max FIFO is available on GitHub https://github.com/BoschSensortec/BMI270-Sensor-API/blob/master/bmi270\_maximum\_fifo.c
  - Optionally: Burst read configuration file from Register <a href="INIT\_DATA">INIT\_DATA</a> and check correctness by comparing it to the data written to the register in the previous step.
- Write <u>INIT\_CTRL.init\_ctrl</u> = 0x01 to complete config load.
   Note: This operation must not be performed more than once after POR or soft reset.
- Wait until Register <a href="INTERNAL\_STATUS.message">INTERNAL\_STATUS.message</a> contains the value 0b0001. This will happen after at most 20 ms.

After the initialization sequence is completed, the power mode of the device is automatically set to "Configuration mode". Now it is possible to switch to other power modes and the device is ready for operation as required and described in the following sections.

For details regarding switching to power modes, Sensor Data (Accel/Gyro and data processing in different modes) and possible filter settings, see <a href="MIL270"><u>BMIL270 data sheet</u></a>

#### 3.4. **FIFO**

BMI270 supports the following FIFO operating modes:

- Streaming mode: overwrites oldest data on FIFO full condition
- FIFO mode: discards newest data on FIFO full condition

The FIFO size is 6 KB and supports the following interrupts:

- FIFO full interrupt
- FIFO watermark interrupt

FIFO is enabled for accelerometer data with <u>FIFO\_CONFIG\_1.fifo\_acc\_en</u>=0b1, for gyroscope data with <u>FIFO\_CONFIG\_1.fifo\_gyr\_en</u>=0b1, and auxiliary interface (e.g. magnetometer) data with <u>FIFO\_CONFIG\_1.fifo\_aux\_en=0b1</u> (0b0=disabled).

The FIFO may be used in all power modes of BMI270. For further details on FIFO refer Chapter 4.7 of BMI270 data sheet

| Bit     | 7        | 6    | 5        | 4    | 3 | 2 | 1        | 0 |
|---------|----------|------|----------|------|---|---|----------|---|
| Content | fh_mode< | 1:0> | fh_parm< | 3:0> |   |   | reserved |   |

FIFO header contains information on fh\_mode and fh\_param as shown by bit-field definition.

#### 3.5. General Interrupt Pin Configuration

#### **Electrical Interrupt Pin Behavior**

Both interrupt pins PIN1 and PIN2 can be configured to show the desired electrical behavior. Interrupt pins can be enabled in <a href="INT1\_IO\_CTRL.output\_en">INT1\_IO\_CTRL.output\_en</a> and <a href="INT2\_IO\_CTRL.output\_en">INT2\_IO\_CTRL.output\_en</a>. The characteristic of the output driver of the interrupt pins may be configured with bits <a href="INT1\_IO\_CTRL.od">INT1\_IO\_CTRL.od</a> and <a href="INT2\_IO\_CTRL.od">INT1\_IO\_CTRL.od</a> and <a hr

The electrical behavior of the Interrupt pins, whenever an interrupt is triggered, can be configured as either "active-high" or "active-low" via INT1 IO CTRL.IVI or INT2 IO CTRL.IVI.

Both interrupt pins can be configured as input pins via <a href="INT1\_IO\_CTRL.input\_en">INT1\_IO\_CTRL.input\_en</a> and <a href="INT2\_IO\_CTRL.input\_en">INT1\_IO\_CTRL.input\_en</a> and <a href="INT2\_IO\_CTRL.input\_en">IO\_IO\_CTRL.input\_en</a> and <a href=

BMI270 supports edge and level triggered interrupt inputs, this can be configured through FIFO\_CONFIG1.fifo\_tag\_int1\_en and FIFO\_CONFIG1.fifo\_tag\_int2\_en.

BMI270 supports non-latched and latched interrupts modes for data ready, FIFO watermark, FIFO full, error, and the advanced feature interrupts. The mode is selected by <a href="INT\_LATCH.int\_latch">INT\_LATCH.int\_latch</a>. Non-latched interrupts are designed for systems using edge triggered interrupts, latched interrupts are designed for systems using level-triggered interrupts.

In latched mode an asserted interrupt status in <a href="INT\_STATUS\_0">INT\_STATUS\_0</a> (advanced feature interrupts) or <a href="INT\_STATUS\_1">INT\_STATUS\_1</a> (data ready, FIFO and error interrupts) and the selected pin are reset if the corresponding status register is read. If the interrupt activation condition still holds when the interrupt is reset, the interrupt status and pin are asserted again. If more than one interrupt pin is used in latched mode, all interrupts in <a href="INT\_STATUS\_0">INT\_STATUS\_0</a> should be mapped to one interrupt pin and all interrupts in <a href="INT\_STATUS\_1">INT\_STATUS\_1</a> should be mapped to the other interrupt pin. If just one interrupt pin is used all interrupts may be mapped to this interrupt pin.

In the non-latched mode the selected pin are reset as soon as the activation condition is not valid anymore. The interrupt status bits are active until read by the host.

#### Interrupt Pin Mapping

The data ready, FIFO watermark, FIFO full, error, and the advanced feature interrupts are mapped to the external INT1 or INT2 pins by setting the corresponding bits in the Registers INT MAP DATA, INT1 MAP FEAT and INT2 MAP FEAT. To unmap these interrupts, the corresponding bits must be reset.

Once an interrupt triggered the output pin, the host can derive the source of the interrupt of the corresponding status bit in the Register:  $\underline{INT}$   $\underline{STATUS}$   $\underline{0}$  and  $\underline{INT}$   $\underline{STATUS}$   $\underline{1}$ .

## 4. Register Description

#### 4.1. General Remarks

This section contains register definitions. REG[x]<y> denotes bit y in byte x in register REG. Val(Name) is the value contained in the register interpreted as non-negative binary number. When writing to reserved bits, '0' should be written if not stated different.

For most of the registers auto address increment applies for, with the exception of the registers below, which trap the address:

- FIFO DATA
- INIT DATA

Register read from a burst read must remain consistent. In order to ensure this, when a read starts in one register of a group, the registers in this group are shadowed:

• STATUS, DATA\_x, SENSORTIME\_x, TEMPERATURE\_x, FIFO\_LENGTH\_x

The registers listed below are clear-on-read:

- ERR\_REG
- <u>STATUS.drdy\_acc</u> (cleared when <u>DATA\_9.acc\_x\_15\_8</u> is read),
- STATUS.drdy\_gyr (cleared when DATA\_15.gyr\_x\_15\_8 is read)
- STATUS.drdy aux (cleared when DATA 1.aux x 15 8 is read)
- EVENT
- INT STATUS 0
- INT\_STATUS\_1

The register clearance happens, when bit 0 of the corresponding register is read.

## 4.2. Register Map

|  | read/write | read only | write only | reserved |
|--|------------|-----------|------------|----------|
|--|------------|-----------|------------|----------|

| Corresponding to BMI270  | mayfife thin version 4.1     | register man      | version 4  |
|--------------------------|------------------------------|-------------------|------------|
| Corresponding to Divizio | _IIIaxiiio.wiii versioii 4.1 | ., register illap | version 4. |

|                             |                       | 1                    | Corresponding to BMI270_maxfifo.tbin version 4.1, register |                                       |             |          |                           |                            |                   | on 4.1                   |
|-----------------------------|-----------------------|----------------------|------------------------------------------------------------|---------------------------------------|-------------|----------|---------------------------|----------------------------|-------------------|--------------------------|
| Registe<br>r<br>Addres<br>s | Register<br>Name      | Defaul<br>t<br>Value | 7 6 5 4 3 2                                                |                                       |             |          |                           |                            | 1                 | 0                        |
| 0x7E                        | CMD                   | 0x00                 |                                                            |                                       |             | cr       | nd                        |                            |                   |                          |
| 0x7D                        | PWR_CTRL              | 0x00                 |                                                            | rese                                  | rved        |          | temp_en                   | acc_en                     | gyr_en            | aux_en                   |
| 0x7C                        | PWR CONF              | 0x03                 |                                                            | reserved fup_en                       |             |          |                           |                            |                   | adv_po<br>wer_sav<br>e   |
| 0x7B                        | -                     | -                    |                                                            |                                       |             | rese     | rved                      |                            |                   |                          |
|                             | -                     | -                    |                                                            |                                       |             | rese     | rved                      |                            |                   |                          |
| 0x78                        | -                     | -                    |                                                            |                                       |             | rese     | rved                      |                            |                   |                          |
| 0x77                        | OFFSET_6              | 0x00                 | gyr_gain<br>_en                                            | gyr_usr_off_z_9_8   gyr_usr_off_y_9_8 |             |          |                           |                            |                   | off_x_9_8                |
| 0x76                        | OFFSET_5              | 0x00                 |                                                            |                                       |             | gyr_usr_ | off_z_7_0                 |                            |                   |                          |
| 0x75                        | OFFSET_4              | 0x00                 |                                                            |                                       |             | gyr_usr_ | off_y_7_0                 |                            |                   |                          |
| 0x74                        | OFFSET_3              | 0x00                 |                                                            |                                       |             | gyr_usr_ | off_x_7_0                 |                            |                   |                          |
| 0x73                        | OFFSET_2              | 0x00                 |                                                            |                                       |             | off_a    | ıcc_z                     |                            |                   |                          |
| 0x72                        | OFFSET_1              | 0x00                 |                                                            |                                       |             | off_a    | ісс_у                     |                            |                   |                          |
| 0x71                        | OFFSET_0              | 0x00                 |                                                            |                                       |             | off_a    | ıcc_x                     |                            |                   |                          |
| 0x70                        | NV_CONF               | 0x00                 |                                                            | rese                                  | erved       |          | acc_off_<br>en            | i2c_wdt_<br>en             | i2c_wdt_<br>sel   | spi_en                   |
| 0x6F                        | -                     | -                    |                                                            |                                       |             | rese     | rved                      |                            |                   |                          |
| 0x6E                        | GYR SELF<br>TEST_AXES | 0x00                 |                                                            | rese                                  | erved       |          | gyr_axis<br>_z_ok         | gyr_axis<br>_y_ok          | gyr_axis<br>_x_ok | gyr_st_a<br>xes_don<br>e |
| 0x6D                        | ACC SELF TEST         | 0x00                 |                                                            | rese                                  | erved       |          | acc_self<br>_test_a<br>mp | acc_self<br>_test_si<br>gn | reserved          | acc_self<br>_test_en     |
| 0x6C                        | <u>DRV</u>            | 0xFF                 | io_pad_i<br>2c_b2                                          |                                       | io_pad_drv2 |          | io_pad_i<br>2c_b1         |                            | io_pad_drv1       |                          |
| 0x6B                        | <u>IF_CONF</u>        | 0x00                 | rese                                                       | rved                                  | aux_en      | ois_en   | rese                      | rved                       | spi3_ois          | spi3                     |
| 0x6A                        | NVM_CONF              | 0x00                 |                                                            |                                       | rese        | rved     |                           |                            | nvm_pro<br>g_en   | reserved                 |
| 0x69                        | -                     | 0x00                 | reserved                                                   |                                       |             |          |                           |                            |                   |                          |
| 0x68                        | AUX_IF_TRI<br>M       | 0x01                 | reserved asda_pup                                          |                                       |             |          |                           |                            | pupsel            |                          |
| 0x67                        | -                     | -                    |                                                            |                                       |             | rese     | rved                      |                            |                   |                          |
|                             | -                     | -                    |                                                            |                                       |             | rese     | rved                      |                            |                   |                          |
| 0x60                        | -                     | -                    |                                                            | reserved reserved                     |             |          |                           |                            |                   |                          |

|      | T                  |      |                                        |                                                                     |                 |                           |               |               |                  |                       |
|------|--------------------|------|----------------------------------------|---------------------------------------------------------------------|-----------------|---------------------------|---------------|---------------|------------------|-----------------------|
| 0x5F | INTERNAL E<br>RROR | 0x00 | reserved                               |                                                                     |                 | feat_eng<br>_disable<br>d | reserved      | int_err_2     | int_err_1        | reserved              |
| 0x5E | <u>INIT_DATA</u>   | 0x00 |                                        |                                                                     |                 | da                        | ıta           |               |                  |                       |
| 0x5D | -                  | -    |                                        |                                                                     |                 | rese                      | rved          |               |                  |                       |
| 0x5C | INIT_ADDR_<br>1    | 0x00 |                                        |                                                                     |                 | base_                     | _11_4         |               |                  |                       |
| 0x5B | INIT_ADDR_<br>0    | 0x00 |                                        | reserved base_0_3                                                   |                 |                           |               |               |                  |                       |
| 0x5A | -                  | -    |                                        | reserved                                                            |                 |                           |               |               |                  |                       |
| 0x59 | INIT_CTRL          | 0x00 | init_ctrl                              |                                                                     |                 |                           |               | ı             | 1                |                       |
| 0x58 | INT_MAP_DA<br>TA   | 0x00 | err_int2 drdy_int fwm_int ffull_int2   |                                                                     |                 | ffull_int2                | err_int1      | drdy_int<br>1 | fwm_int<br>1     | ffull_int1            |
| 0x57 | INT2 MAP F<br>EAT  | 0x00 |                                        | reserved                                                            |                 |                           |               |               |                  |                       |
| 0x56 | INT1 MAP F EAT     | 0x00 |                                        |                                                                     |                 | rese                      | rved          |               |                  |                       |
| 0x55 | INT_LATCH          | 0x00 |                                        |                                                                     |                 | reserved                  |               |               |                  | int_latch             |
| 0x54 | INT2_IO_CT<br>RL   | 0x00 |                                        | reserved input_e                                                    |                 |                           | output_e<br>n | od            | lvl              | reserved              |
| 0x53 | INT1_IO_CT         | 0x00 | reserved input_                        |                                                                     |                 | input_en                  | output_e<br>n | od            | lvl              | reserved              |
| 0x52 | ERR REG M          | 0x00 | aux_err fifo_err reserved internal_err |                                                                     |                 |                           |               | fatal_err     |                  |                       |
| 0x51 | -                  | -    |                                        |                                                                     |                 | rese                      | rved          |               |                  |                       |
| 0x50 | -                  | -    |                                        |                                                                     |                 | rese                      |               |               |                  |                       |
| 0x4F | AUX_WR_DA TA       | 0x02 |                                        |                                                                     |                 | write                     |               |               |                  |                       |
| 0x4E | AUX_WR_AD<br>DR    | 0x4C |                                        |                                                                     |                 | write                     | _addr         |               |                  |                       |
| 0x4D | AUX RD_AD<br>DR    | 0x42 |                                        |                                                                     |                 | read <sub>-</sub>         | _addr         |               |                  |                       |
| 0x4C | AUX IF CON         | 0x83 | aux_ma<br>nual_en                      | aux_fcu<br>_write_e<br>n                                            | rese            | rved                      | man_re        | d_burst       | aux_rc           | I_burst               |
| 0x4B | AUX_DEV_ID         | 0x20 |                                        |                                                                     | i2e             | c_device_ad               | ldr           |               |                  | reserved              |
| 0x4A | SATURATION         | 0x00 | rese                                   | rved                                                                | gyr_z           | gyr_y                     | gyr_x         | acc_z         | acc_y            | acc_x                 |
| 0x49 | FIFO_CONFI<br>G_1  | 0x10 | fifo_gyr_<br>en                        | fifo_acc<br>_en                                                     | fifo_aux<br>_en | fifo_hea<br>der_en        | fifo_tag      | _int2_en      | fifo_tag_        | _int1_en              |
| 0x48 | FIFO_CONFI<br>G_0  | 0x02 |                                        |                                                                     | rese            | rved                      |               |               | fifo_time<br>_en | fifo_stop<br>_on_full |
| 0x47 | FIFO_WTM_          | 0x02 |                                        | reserved                                                            |                 |                           | fifo_v        | vater_mark_   | <del>-</del>     |                       |
| 0x46 | FIFO_WTM_          | 0x00 |                                        |                                                                     |                 | fifo_water_               | _mark_7_0     |               |                  |                       |
| 0x45 | FIFO DOWN S        | 0x88 | acc_fifo<br>_filt_dat<br>a             | _filt_dat   acc_fifo_downs   gyr_fifo_   gyr_fifo_downs   filt_data |                 |                           |               |               | ns               |                       |
|      |                    |      |                                        | a aux_offset aux_odr                                                |                 |                           |               |               |                  |                       |

| 0x43 | GYR_RANGE         | 0x00 |                             | rese             | rved             |             | ois_rang<br>e       |             | gyr_range |                  |  |  |
|------|-------------------|------|-----------------------------|------------------|------------------|-------------|---------------------|-------------|-----------|------------------|--|--|
| 0x42 | GYR_CONF          | 0xA9 | gyr_filter gyr_nois gyr_bwp |                  |                  |             | gyr.                | _odr        |           |                  |  |  |
| 0x41 | ACC_RANGE         | 0x02 |                             |                  | rese             | rved        |                     |             | acc_ı     | range            |  |  |
| 0x40 | ACC_CONF          | 0xA8 | acc_filte<br>r_perf         |                  | acc_bwp          |             |                     | acc         | _odr      |                  |  |  |
| 0x3F | -                 | =    |                             |                  |                  | rese        | rved                |             |           |                  |  |  |
|      | -                 | -    |                             |                  |                  | rese        | rved                |             |           |                  |  |  |
| 0x27 | -                 | -    |                             |                  |                  | rese        | rved                |             |           |                  |  |  |
| 0x26 | FIFO_DATA         | 0x00 |                             |                  | <u> </u>         | fifo_       | data                |             |           |                  |  |  |
| 0x25 | FIFO_LENGT<br>H_1 | 0x00 | rese                        | rved             |                  |             | fifo_byte_co        | ounter_13_8 |           |                  |  |  |
| 0x24 | FIFO LENGT<br>H 0 | 0x00 |                             |                  |                  | fifo_byte_c | ounter_7_0          |             |           |                  |  |  |
| 0x23 | TEMPERATU<br>RE_1 | 0x80 |                             |                  |                  | tmp_da      | ta_15_8             |             |           |                  |  |  |
| 0x22 | TEMPERATU<br>RE 0 | 0x00 |                             |                  |                  | tmp_da      | ata_7_0             |             |           |                  |  |  |
| 0x21 | INTERNAL S TATUS  | 0x00 |                             | Reserved me      |                  |             |                     |             |           | message          |  |  |
| 0x20 | Reserved          | 0x00 |                             |                  |                  | Rese        | erved               |             |           |                  |  |  |
| 0x1F | Reserved          | 0x00 |                             |                  |                  |             | erved               |             |           |                  |  |  |
| 0x1E | GYR CAS           | 0x00 | reserved factor_zx          |                  |                  |             |                     |             |           |                  |  |  |
| 0x1D | INT_STATUS _1     | 0x00 | acc_drd<br>y_int            | gyr_drdy<br>_int | aux_drd<br>y_int | rese        | rved                | err_int     | fwm_int   | ffull_int        |  |  |
| 0x1C | INT_STATUS<br>_0  | 0x00 |                             |                  |                  | rese        | rved                |             |           |                  |  |  |
| 0x1B | <u>EVENT</u>      | 0x01 |                             | reserved         |                  |             | error_code          |             | reserved  | por_dete<br>cted |  |  |
| 0x1A | SENSORTIM<br>E 2  | 0x00 |                             |                  |                  | sensor_tir  | me_23_16            |             |           |                  |  |  |
| 0x19 | SENSORTIM<br>E 1  | 0x00 |                             |                  |                  | sensor_ti   | me_15_8             |             |           |                  |  |  |
| 0x18 | SENSORTIM<br>E_0  | 0x00 |                             |                  |                  | sensor_t    | time_7_0            |             |           |                  |  |  |
| 0x17 | DATA_19           | 0x00 |                             |                  |                  | gyr_z       | _15_8               |             |           |                  |  |  |
| 0x16 | <u>DATA_18</u>    | 0x00 |                             |                  |                  | gyr_z       | z_7_0               |             |           |                  |  |  |
| 0x15 | DATA_17           | 0x00 |                             |                  |                  | gyr_y       | _15_8               |             |           |                  |  |  |
| 0x14 | DATA_16           | 0x00 |                             |                  |                  | gyr_y       | <mark>/_7_</mark> 0 |             |           |                  |  |  |
| 0x13 | <u>DATA_15</u>    | 0x00 |                             |                  |                  | gyr_x       | _15_8               |             |           |                  |  |  |
| 0x12 | DATA_14           | 0x00 |                             |                  |                  |             | c_7_0               |             |           |                  |  |  |
| 0x11 | <u>DATA_13</u>    | 0x00 |                             |                  |                  |             | _15_8               |             |           |                  |  |  |
| 0x10 | <u>DATA_12</u>    | 0x00 |                             |                  |                  |             | z_7_0               |             |           |                  |  |  |
| 0x0F | DATA_11           | 0x00 |                             |                  |                  |             | _15_8               |             |           |                  |  |  |
| 0x0E | DATA_10           | 0x00 |                             |                  |                  |             | <u>/_7_0</u>        |             |           |                  |  |  |
| 0x0D | DATA_9            | 0x00 |                             |                  |                  |             | _15_8               |             |           |                  |  |  |
| 0x0C | DATA_8            | 0x00 |                             |                  |                  |             | <u>&lt;_7_0</u>     |             |           |                  |  |  |
| 0x0B | DATA_7            | 0x00 |                             | aux_r_15_8       |                  |             |                     |             |           |                  |  |  |

| 0x0A | DATA_6        | 0x00 |                                                        | aux_r_7_0  |  |       |       |  |           |  |  |
|------|---------------|------|--------------------------------------------------------|------------|--|-------|-------|--|-----------|--|--|
| 0x09 | DATA_5        | 0x00 |                                                        | aux_z_15_8 |  |       |       |  |           |  |  |
| 0x08 | DATA_4        | 0x00 |                                                        | aux_z_7_0  |  |       |       |  |           |  |  |
| 0x07 | DATA_3        | 0x00 |                                                        | aux_y_15_8 |  |       |       |  |           |  |  |
| 0x06 | DATA_2        | 0x00 |                                                        | aux_y_7_0  |  |       |       |  |           |  |  |
| 0x05 | DATA_1        | 0x00 | aux_x_15_8                                             |            |  |       |       |  |           |  |  |
| 0x04 | DATA_0        | 0x00 |                                                        |            |  | aux_x | x_7_0 |  |           |  |  |
| 0x03 | <u>STATUS</u> | 0x10 | drdy_ac c drdy_gyr x cmd_rdy reserved aux_bus reserved |            |  |       |       |  | rved      |  |  |
| 0x02 | ERR_REG       | 0x00 | aux_err fifo_err reserved internal_err fatal_err       |            |  |       |       |  | fatal_err |  |  |
| 0x01 | -             | -    | reserved                                               |            |  |       |       |  |           |  |  |
| 0x00 | CHIP_ID       | 0x24 |                                                        |            |  | chip  | o_id  |  |           |  |  |

Register (0x00) CHIP\_ID

DESCRIPTION: Chip identification code

RESET: 0x24

DEFINITION (Go to register map):

| Address | Bit | Name    | Description              | Reset | Access |
|---------|-----|---------|--------------------------|-------|--------|
| 0x00    |     | CHIP_ID |                          | 0x24  |        |
|         | 70  | chip_id | Chip identification code | 0x24  | R      |

Register (0x02) ERR\_REG

DESCRIPTION: Reports sensor error conditions

RESET: 0x00

| Address | Bit | Name         | Description                                                                                                                                                                | Reset | Access |
|---------|-----|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|
| 0x02    |     | ERR_REG      |                                                                                                                                                                            | 0x00  |        |
|         | 0   | fatal_err    | Fatal Error, chip is not in operational state (Boot-, power-system). This flag will be reset only by power-on-reset or softreset.                                          | 0x0   | R      |
|         | 41  | internal_err | Internal error, please contact your Bosch<br>Sensortec regional support team.                                                                                              | 0x0   | R      |
|         | 6   | fifo_err     | Error when a frame is read in streaming mode (so skipping is not possible) and fifo is overfilled (with virtual and/or regular frames). This flag will be reset when read. | 0x0   | R      |
|         | 7   | aux_err      | Error in I2C-Master detected. This flag will be reset when read.                                                                                                           | 0x0   | R      |

Register (0x03) STATUS

**DESCRIPTION: Sensor status flags** 

RESET: 0x10

DEFINITION (Go to register map):

| Address | Bit | Name     | Description                                                                                                                        | Reset | Access |
|---------|-----|----------|------------------------------------------------------------------------------------------------------------------------------------|-------|--------|
| 0x03    |     | STATUS   |                                                                                                                                    | 0x10  |        |
|         | 2   | aux_busy | '1'('0') indicate a (no) Auxiliary sensor interface<br>operation is ongoing triggered via<br>AUX_RD_ADDR, AUX_WR_ADDR or from FCU. | 0x0   | R      |
|         | 4   | cmd_rdy  | CMD decoder status. '0' -> Command in progress<br>'1' -> Command decoder is ready to accept a new command                          | 0x1   | R      |
|         | 5   | drdy_aux | Data ready for Auxiliary sensor. It gets reset, when one Auxiliary sensor DATA register is read out                                | 0x0   | R      |
|         | 6   | drdy_gyr | Data ready for Gyroscope. It gets reset, when one Gyroscope DATA register is read out                                              | 0x0   | R      |
|         | 7   | drdy_acc | Data ready for Accelerometer. It gets reset, when one Accelerometer DATA register is read out                                      | 0x0   | R      |

Register (0x04) DATA\_0 DESCRIPTION: AUX\_X(LSB)

RESET: 0x00

| Address | Bit | Name      | Description                                  |      | Access |
|---------|-----|-----------|----------------------------------------------|------|--------|
| 0x04    |     | DATA_0    |                                              | 0x00 |        |
|         | 70  | aux_x_7_0 | copy of register Val(AUX_IF[1]) in Auxiliary | 0x0  | R      |
|         |     |           | sensor register map.                         |      |        |

Register (0x05) DATA\_1

DESCRIPTION: AUX\_X(MSB)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name       | Description                                    | Reset | Access |
|---------|-----|------------|------------------------------------------------|-------|--------|
| 0x05    |     | DATA_1     |                                                | 0x00  |        |
|         | 70  | aux_x_15_8 | copy of register Val(AUX_IF[1])+1 in Auxiliary | 0x0   | R      |
|         |     |            | sensor register map                            |       |        |

Register (0x06) DATA\_2

DESCRIPTION: AUX\_Y(LSB)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name      | Description                                    | Reset | Access |
|---------|-----|-----------|------------------------------------------------|-------|--------|
| 0x06    |     | DATA_2    |                                                | 0x00  |        |
|         | 70  | aux_y_7_0 | copy of register Val(AUX_IF[1])+2 in Auxiliary | 0x0   | R      |
|         |     |           | sensor register map                            |       |        |

Register (0x07) DATA\_3

DESCRIPTION: AUX\_Y(MSB)

RESET: 0x00

| Address | Bit | Name       | Description                                    | Reset | Access |
|---------|-----|------------|------------------------------------------------|-------|--------|
| 0x07    |     | DATA_3     |                                                | 0x00  |        |
|         | 70  | aux_y_15_8 | copy of register Val(AUX_IF[1])+3 in Auxiliary | 0x0   | R      |
|         |     |            | sensor register map                            |       |        |

Register (0x08) DATA\_4

DESCRIPTION: AUX\_Z(LSB)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name      | Description                                    | Reset | Access |
|---------|-----|-----------|------------------------------------------------|-------|--------|
| 0x08    |     | DATA_4    |                                                | 0x00  |        |
|         | 70  | aux_z_7_0 | copy of register Val(AUX_IF[1])+4 in Auxiliary | 0x0   | R      |
|         |     |           | sensor register map                            |       |        |

Register (0x09) DATA\_5

DESCRIPTION: AUX\_Z(MSB)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name       | Description                                    | Reset | Access |
|---------|-----|------------|------------------------------------------------|-------|--------|
| 0x09    |     | DATA_5     |                                                | 0x00  |        |
|         | 70  | aux_z_15_8 | copy of register Val(AUX_IF[1])+5 in Auxiliary | 0x0   | R      |
|         |     |            | sensor register map                            |       |        |

Register (0x0A) DATA\_6

DESCRIPTION: AUX\_R(LSB)

RESET: 0x00

| Address | Bit | Name      | Description                                    | Reset | Access |
|---------|-----|-----------|------------------------------------------------|-------|--------|
| 0x0A    |     | DATA_6    |                                                | 0x00  |        |
|         | 70  | aux_r_7_0 | copy of register Val(AUX_IF[1])+6 in Auxiliary | 0x0   | R      |
|         |     |           | sensor register map                            |       |        |

Register (0x0B) DATA\_7

DESCRIPTION: AUX\_R(MSB)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name       | Description                                    | Reset | Access |
|---------|-----|------------|------------------------------------------------|-------|--------|
| 0x0B    |     | DATA_7     |                                                | 0x00  |        |
|         | 70  | aux_r_15_8 | copy of register Val(AUX_IF[1])+7 in Auxiliary | 0x0   | R      |
|         |     |            | sensor register map                            |       |        |

Register (0x0C) DATA\_8

DESCRIPTION: ACC\_X(LSB)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name      | Description | Reset | Access |
|---------|-----|-----------|-------------|-------|--------|
| 0x0C    |     | DATA_8    |             | 0x00  |        |
|         | 70  | acc_x_7_0 |             | 0x0   | R      |

Register (0x0D) DATA\_9

DESCRIPTION: ACC\_X(MSB)

RESET: 0x00

DEFINITION (Go to register map):

| Addres | S | Bit | Name       | Description | Reset | Access |
|--------|---|-----|------------|-------------|-------|--------|
| 0x0D   |   |     | DATA_9     |             | 0x00  |        |
|        |   | 70  | acc_x_15_8 |             | 0x0   | R      |

Register (0x0E) DATA\_10

DESCRIPTION: ACC\_Y(LSB)

RESET: 0x00

| Address | Bit | Name      | Description | Reset | Access |
|---------|-----|-----------|-------------|-------|--------|
| 0x0E    |     | DATA_10   |             | 0x00  |        |
|         | 70  | acc_y_7_0 |             | 0x0   | R      |

Register (0x0F) DATA\_11

DESCRIPTION: ACC\_Y(MSB)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name       | Description | Reset | Access |
|---------|-----|------------|-------------|-------|--------|
| 0x0F    |     | DATA_11    |             | 0x00  |        |
|         | 70  | acc_y_15_8 |             | 0x0   | R      |

Register (0x10) DATA\_12

DESCRIPTION: ACC\_Z(LSB)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name      | Description | Reset | Access |
|---------|-----|-----------|-------------|-------|--------|
| 0x10    |     | DATA_12   |             | 0x00  |        |
|         | 70  | acc_z_7_0 |             | 0x0   | R      |

Register (0x11) DATA\_13

DESCRIPTION: ACC\_Z(MSB)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name       | Description | Reset | Access |
|---------|-----|------------|-------------|-------|--------|
| 0x11    |     | DATA_13    |             | 0x00  |        |
|         | 70  | acc_z_15_8 |             | 0x0   | R      |

Register (0x12) DATA\_14

DESCRIPTION: GYR\_X(LSB)

RESET: 0x00

| Address | Bit | Name      | Description | Reset | Access |
|---------|-----|-----------|-------------|-------|--------|
| 0x12    |     | DATA_14   |             | 0x00  |        |
|         | 70  | gyr_x_7_0 |             | 0x0   | R      |

Register (0x13) DATA\_15

DESCRIPTION: GYR\_X(MSB)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name       | Description | Reset | Access |
|---------|-----|------------|-------------|-------|--------|
| 0x13    |     | DATA_15    |             | 0x00  |        |
|         | 70  | gyr_x_15_8 |             | 0x0   | R      |

Register (0x14) DATA\_16

DESCRIPTION: GYR\_Y(LSB)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name      | Description | Reset | Access |
|---------|-----|-----------|-------------|-------|--------|
| 0x14    |     | DATA_16   |             | 0x00  |        |
|         | 70  | gyr_y_7_0 |             | 0x0   | R      |

Register (0x15) DATA\_17

DESCRIPTION: GYR\_Y(MSB)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name       | Description | Reset | Access |
|---------|-----|------------|-------------|-------|--------|
| 0x15    |     | DATA_17    |             | 0x00  |        |
|         | 70  | gyr_y_15_8 |             | 0x0   | R      |

Register (0x16) DATA\_18

DESCRIPTION: GYR\_Z(LSB)

RESET: 0x00

| Address | Bit | Name      | Description | Reset | Access |
|---------|-----|-----------|-------------|-------|--------|
| 0x16    |     | DATA_18   |             | 0x00  |        |
|         | 70  | gyr_z_7_0 |             | 0x0   | R      |

Register (0x17) DATA\_19

DESCRIPTION: GYR\_Z(MSB)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name       | Description | Reset | Access |
|---------|-----|------------|-------------|-------|--------|
| 0x17    |     | DATA_19    |             | 0x00  |        |
|         | 70  | gyr_z_15_8 |             | 0x0   | R      |

Register (0x18) SENSORTIME\_0

DESCRIPTION: Sensor time <7:0>

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name            | Description       | Reset | Access |
|---------|-----|-----------------|-------------------|-------|--------|
| 0x18    |     | SENSORTIME_0    |                   | 0x00  |        |
|         | 70  | sensor_time_7_0 | Sensor time <7:0> | 0x0   | R      |

Register (0x19) SENSORTIME\_1

DESCRIPTION: Sensor time <15:8>

RESET: 0x00

| Address | Bit | Name             | Description         | Reset | Access |
|---------|-----|------------------|---------------------|-------|--------|
| 0x19    |     | SENSORTIME_1     |                     | 0x00  |        |
|         | 70  | sensor_time_15_8 | Sensor time <15:8>. | 0x0   | R      |

## Register (0x1A) SENSORTIME\_2

DESCRIPTION: Sensor time <23:16>

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Reset | Access |
|---------|-----|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|
| 0x1A    |     | SENSORTIME_2      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x00  |        |
|         | 70  | sensor_time_23_16 | Sensor time <23:16> The sensor time is a 24 bit counter available in suspend, low power, and normal mode. The value of the SENSORTIME register is shadowed, when it is read in a burst read with the data register at the beginning of the operation and the shadowed value is returned. When the fifo is read the register is shadowed, whenever a new frame is read. The resolution of the sensor_time is 39.0625 us, and it is synchrounous to ODR. The register wraps if it reaches 0xFFFFFF. | 0x0   | R      |

## Register (0x1B) EVENT

DESCRIPTION: Sensor event flags. Will be cleared on read when bit 0 is sent out over the bus.

RESET: 0x01

| Address | Bit | Name         | Descrip  | tion                                                          |                   | Reset | Access |
|---------|-----|--------------|----------|---------------------------------------------------------------|-------------------|-------|--------|
| 0x1B    |     | EVENT        |          |                                                               | 0x01              |       |        |
|         | 0   | por_detected |          | 1' after device power up or softreset, '0' after status read. |                   |       | R      |
|         | 42  | error_code   | Error co | des for persistent er                                         | rrors             | 0x0   | R      |
|         |     |              | Value    | Name                                                          | Description       |       |        |
|         |     |              | 0x00     | no_error                                                      | no error is       |       |        |
|         |     |              |          |                                                               | reported          |       |        |
|         |     |              | 0x01     | acc_err                                                       | error in Register |       |        |
|         |     |              |          |                                                               | ACC_CONF          |       |        |
|         |     |              | 0x02     | gyr_err                                                       | error in Register |       |        |
|         |     |              |          |                                                               | GYR_CONF          |       |        |
|         |     |              | 0x03     | acc_and_gyr_err                                               | error in          |       |        |
|         |     |              |          |                                                               | Registers         |       |        |
|         |     |              |          |                                                               | ACC_GYR &         |       |        |
|         |     |              |          |                                                               | GYR_CONF          |       |        |

Register (0x1C) INT\_STATUS\_0

**DESCRIPTION: Reserved** 

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name         | Description | Reset | Access |
|---------|-----|--------------|-------------|-------|--------|
| 0x1C    |     | INT_STATUS_0 |             | 0x00  |        |
|         | 70  | reserved     | Reserved    | 0x0   | R      |

## Register (0x1D) INT\_STATUS\_1

DESCRIPTION: Interrupt Status 1. Will be cleared on read when bit 0 is sent out over the bus.

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name         | Description                        | Reset | Access |
|---------|-----|--------------|------------------------------------|-------|--------|
| 0x1D    |     | INT_STATUS_1 |                                    | 0x00  |        |
|         | 0   | ffull_int    | FIFO Full Interrupt                | 0x0   | R      |
|         | 1   | fwm_int      | FIFO Watermark Interrupt           | 0x0   | R      |
|         | 2   | err_int      | ERROR Interrupt                    | 0x0   | R      |
|         | 5   | aux_drdy_int | Auxiliary Data Ready Interrupt     | 0x0   | R      |
|         | 6   | gyr_drdy_int | Gyroscope Data Ready Interrupt     | 0x0   | R      |
|         | 7   | acc_drdy_int | Accelerometer Data Ready Interrupt | 0x0   | R      |

## Register (0x1E) GYR\_CAS

DESCRIPTION: Register for gyroscope data post processing

RESET: 0x00

| Address | Bit | Name      | Description                                          | Reset | Access |
|---------|-----|-----------|------------------------------------------------------|-------|--------|
| 0x1E    |     | GYR_CAS   |                                                      | 0x00  |        |
|         | 60  | factor_zx | Factor to further optimize the gyroscope performance | 0x0   | R      |

Register (0x1F) Reserved

**DESCRIPTION: Reserved** 

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name     | Description | Reset | Access |
|---------|-----|----------|-------------|-------|--------|
| 0x1F    |     | Reserved |             | 0x00  |        |
|         | 70  | Reserved | Reserved    | 0x0   | R      |

Register (0x20) Reserved

**DESCRIPTION: Reserved** 

RESET: 0x00

| Address | Bit | Name     | Description | Reset | Access |
|---------|-----|----------|-------------|-------|--------|
| 0x20    |     | Reserved |             | 0x00  |        |
|         | 70  | Reserved | Reserved    | 0x0   | R      |

## Register (0x21) INTERNAL\_STATUS

DESCRIPTION: Error bits and message indicating internal status

RESET: 0x00

| Addres<br>s | Bit    | Name                | Descrip                                       | otion                                                                          |                                                                                                                                                      | Rese<br>t | Acces<br>s |
|-------------|--------|---------------------|-----------------------------------------------|--------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|------------|
| 0x21        |        | INTERNAL_STATU<br>S |                                               |                                                                                |                                                                                                                                                      | 0x00      |            |
|             | 3 0    | message             | Internal Valu e 0x00 0x01 0x02 0x03 0x04 0x05 | Status Message Name  not_init  init_ok  init_err  drv_err  sns_stop  nvm_error | Description  ASIC is not initialized ASIC initialized Initialization error Invalid driver Sensor stopped Internal error while accessing NVM Internal | 0x0       | R          |
|             |        |                     | 0x07                                          | r compat_error                                                                 | error while accessing NVM and Initialization error Compatibilit y error                                                                              |           |            |
|             | 7<br>4 | Reserved            | Reserve                                       | ed                                                                             |                                                                                                                                                      | 0x0       | R          |

#### Register (0x22) TEMPERATURE 0

DESCRIPTION: Temperature LSB; The temperature is disabled when all sensors are in suspend. The output word of the 16-bit temperature sensor is valid if the Gyroscope is in normal mode, i.e. gyr\_pmu\_status=1. The resolution is 1/2^9 K/LSB. The absolute accuracy of the temperature is in the order of:

0x7FFF -> 87-1/2^9 °C 0x0000 -> 23°C 0x8001 -> -41+1/2^9 °C 0x8000 -> invalid

If the Gyroscope is in normal mode (see register PMU\_STATUS), the temperature is updated every 10 ms (+-12%), if the gyroscope is in standby mode or fast-power up mode, the temperature is updated ever 1.28 s aligned with bit 15 of the register SENSORTIME.

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name          | Description        | Reset | Access |
|---------|-----|---------------|--------------------|-------|--------|
| 0x22    |     | TEMPERATURE_0 |                    | 0x00  |        |
|         | 70  | tmp_data_7_0  | Temperature value. | 0x0   | R      |

## Register (0x23) TEMPERATURE\_1

DESCRIPTION: Contains the MSBs of temperature sensor value

RESET: 0x80

| Address | Bit | Name          | Description       | Reset | Access |
|---------|-----|---------------|-------------------|-------|--------|
| 0x23    |     | TEMPERATURE_1 |                   | 0x80  |        |
|         | 70  | tmp_data_15_8 | Temperature LSBs. | 0x80  | R      |

Register (0x24) FIFO\_LENGTH\_0

DESCRIPTION: FIFO byte count register (LSB)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name                  | Description                                                                                                                                                                                                                                                                                                                      | Reset | Access |
|---------|-----|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|
| 0x24    |     | FIFO_LENGTH_0         |                                                                                                                                                                                                                                                                                                                                  | 0x00  |        |
|         | 70  | fifo_byte_counter_7_0 | Current fill level of FIFO buffer This includes the skip frame for a full fifo. An empty FIFO corresponds to 0x000. The byte counter may be reset by reading out all frames from the FIFO buffer or when the FIFO is reset through the register CMD. The byte counter is updated each time a complete frame was read or written. | 0x0   | R      |

Register (0x25) FIFO\_LENGTH\_1

DESCRIPTION: FIFO byte count register (MSB)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name                   | Description                | Reset | Access |
|---------|-----|------------------------|----------------------------|-------|--------|
| 0x25    |     | FIFO_LENGTH_1          |                            | 0x00  |        |
|         | 50  | fifo_byte_counter_13_8 | FIFO byte counter bits 138 | 0x0   | R      |

Register (0x26) FIFO\_DATA

DESCRIPTION: FIFO data output register

RESET: 0x00

| Address | Bit | Name      | Description                                                                                                                                                                                                                                                                                                                                                                              | Reset | Access |
|---------|-----|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|
| 0x26    |     | FIFO_DATA |                                                                                                                                                                                                                                                                                                                                                                                          | 0x00  |        |
|         | 70  | fifo_data | FIFO read data (8 bits)  Data format depends on the setting of register FIFO_CONFIG. The FIFO data are organized in frames. The new data flag is preserved.  Read burst access must be used, the address will not increment when the read burst reads at the address of FIFO_DATA. When a frame is only partially read out it is retransmitted including the header at the next readout. | 0x0   | R      |

## Register (0x40) ACC\_CONF

DESCRIPTION: Sets the output data rate, the bandwidth, and the performance mode of the acceleration sensor

RESET: 0xA8

| Address | Bit | Name     | Descrip      | tion               | Reset                               | Access |    |
|---------|-----|----------|--------------|--------------------|-------------------------------------|--------|----|
| 0x40    |     | ACC_CONF |              |                    |                                     |        |    |
|         | 30  | acc_odr  |              | Hz. The outp       | 0x8                                 | RW     |    |
|         |     |          | Value        | Name               | Description                         |        |    |
|         |     |          | 0x00         | reserved           | Reserved                            |        |    |
|         |     |          | 0x01         | odr_0p78           | 25/32                               |        |    |
|         |     |          | 0x02         | odr_1p5            | 25/16                               |        |    |
|         |     |          | 0x03         | odr_3p1            | 25/8                                |        |    |
|         |     |          | 0x04         | odr_6p25           | 25/4                                |        |    |
|         |     |          | 0x05         | odr_12p5           | 25/2                                |        |    |
|         |     |          | 0x06         | odr_25             | 25                                  |        |    |
|         |     |          | 0x07         | odr_50             | 50                                  |        |    |
|         |     |          | 0x08         | odr_100            | 100                                 |        |    |
|         |     |          | 0x09<br>0x0a | odr_200<br>odr_400 | 200<br>400                          |        |    |
|         |     |          | 0x0a<br>0x0b | odr_800            | 800                                 |        |    |
|         |     |          | 0x0c         | odr_1k6            | 1600                                |        |    |
|         |     |          | 0x0d         | odr_3k2            | Reserved                            |        |    |
|         |     |          | 0x0e         | odr_6k4            | Reserved                            |        |    |
|         |     |          | 0x0f         | odr_12k8           | Reserved                            |        |    |
|         | 64  | acc_bwp  | Bandwic      | Ith paramete       | r determines filter                 | 0x2    | RW |
|         |     |          | configura    | ation (acc_fi      |                                     |        |    |
|         |     |          |              |                    | ode (acc_filt_perf=0)               |        |    |
|         |     |          | Value        | Name               | Description                         |        |    |
|         |     |          | 0x00         | osr4_avg1          | — — — ·                             |        |    |
|         |     |          |              |                    | OSR4 mode;<br>acc_filt_perf = 0 ->  |        |    |
|         |     |          |              |                    | no averaging                        |        |    |
|         |     |          | 0x01         | osr2_avg2          | acc_filt_perf = 1 ->                |        |    |
|         |     |          |              |                    | OSR2 mode;                          |        |    |
|         |     |          |              |                    | acc_filt_perf = 0 ->                |        |    |
|         |     |          |              |                    | average 2 samples                   |        |    |
|         |     |          | 0x02         | norm_avg4          | — — — ·                             |        |    |
|         |     |          |              |                    | normal mode;                        |        |    |
|         |     |          |              |                    | acc_filt_perf = 0 ->                |        |    |
|         |     |          | 002          | aia aug0           | average 4 samples                   |        |    |
|         |     |          | 0x03         | cic_avg8           | acc_filt_perf = 1 -><br>CIC mode;   |        |    |
|         |     |          |              |                    | acc_filt_perf = 0 ->                |        |    |
|         |     |          |              |                    | acc_mc_pen = 0 => average 8 samples |        |    |
|         |     |          |              |                    | avorago o samples                   |        |    |

|   |                 | 0x04<br>0x05<br>0x06 | res_ave        | 332<br>364 | acc_filt_perf = 1 -> Reserved; acc_filt_perf = 0 -> average 16 samples acc_filt_perf = 1 -> Reserved; acc_filt_perf = 0 -> average 32 samples acc_filt_perf = 1 -> Reserved; acc_filt_perf = 0 -> average 64 samples acc_filt_perf = 1 -> Reserved; acc_filt_perf = 1 -> Reserved; acc_filt_perf = 1 -> Reserved; |     |    |
|---|-----------------|----------------------|----------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|----|
|   |                 |                      |                |            | average 128 samples                                                                                                                                                                                                                                                                                               |     |    |
| 7 | acc_filter_perf | Select a mode: Value | ccelerom  Name |            | lter performance                                                                                                                                                                                                                                                                                                  | 0x1 | RW |
|   |                 | 0x00<br>0x01         | ulp<br>hp      | -          | er optimized<br>ormance opt.                                                                                                                                                                                                                                                                                      |     |    |

## Register (0x41) ACC\_RANGE

DESCRIPTION: Selection of the Accelerometer g-range

RESET: 0x02

| Address | Bit | Name      | Descrip  | tion          | Reset       | Access |  |
|---------|-----|-----------|----------|---------------|-------------|--------|--|
| 0x41    |     | ACC_RANGE |          |               |             | 0x02   |  |
|         | 10  | acc_range | Accelero | ometer g-rang | 0x2         | RW     |  |
|         |     |           | Value    | Name          | Description |        |  |
|         |     |           | 0x00     | range_2g      | +/-2g       |        |  |
|         |     |           | 0x01     | range_4g      | +/-4g       |        |  |
|         |     |           | 0x02     | range_8g      | +/-8g       |        |  |
|         |     |           | 0x03     | range 16g     | +/-16g      |        |  |

## Register (0x42) GYR\_CONF

DESCRIPTION: Sets the output data rate and the bandwidth of the Gyroscope in the sensor RESET: 0xA9

| Address | Bit | Name            | Descrip | tion          | Reset                 | Access |    |
|---------|-----|-----------------|---------|---------------|-----------------------|--------|----|
| 0x42    |     | GYR_CONF        |         |               | 0xA9                  |        |    |
|         | 30  | gyr_odr         | ODR in  | Hz            | 0x9                   | RW     |    |
|         |     |                 | Value   | Name          | Description           |        |    |
|         |     |                 | 0x00    | reserved      | Reserved              |        |    |
|         |     |                 | 0x01    | odr_0p78      | Reserved              |        |    |
|         |     |                 | 0x02    | odr_1p5       | Reserved              |        |    |
|         |     |                 | 0x03    | odr_3p1       | Reserved              |        |    |
|         |     |                 | 0x04    | odr_6p25      | Reserved              |        |    |
|         |     |                 | 0x05    | odr_12p5      | Reserved              |        |    |
|         |     |                 | 0x06    | odr_25        | 25                    |        |    |
|         |     |                 | 0x07    | odr_50        | 50                    |        |    |
|         |     |                 | 0x08    | odr_100       | 100                   |        |    |
|         |     |                 | 0x09    | odr_200       | 200                   |        |    |
|         |     |                 | 0x0a    | odr_400       | 400                   |        |    |
|         |     |                 | 0x0b    | odr_800       | 800                   |        |    |
|         |     |                 | 0x0c    | odr_1k6       | 1600                  |        |    |
|         |     |                 | 0x0d    | odr_3k2       | 3200                  |        |    |
|         |     |                 | 0x0e    | odr_6k4       | Reserved              |        |    |
|         |     |                 | 0x0f    | odr_12k8      | Reserved              |        |    |
|         | 54  | gyr_bwp         | The Gyr | oscope ban    | 0x2                   | RW     |    |
|         |     |                 |         | the 3 dB cut  |                       |        |    |
|         |     |                 | -       | er for the se |                       |        |    |
|         |     |                 | Value   |               | escription            |        |    |
|         |     |                 | 0x00    |               | SR4 mode              |        |    |
|         |     |                 | 0x01    |               | SR2 mode              |        |    |
|         |     |                 | 0x02    |               | ormal mode            |        |    |
|         |     |                 | 0x03    |               | eserved               | 0x0    |    |
|         | 6   | gyr_noise_perf  |         |               |                       |        | RW |
|         |     |                 | Value   |               | escription            |        |    |
|         |     |                 | 0x00    | •             | ower optimized        |        |    |
|         |     |                 | 0x01    |               | erformance opt.       |        |    |
|         | 7   | gyr_filter_perf |         |               | ter performance mode: | 0x1    | RW |
|         |     |                 | Value   |               | escription            |        |    |
|         |     |                 | 0x00    |               | ower optimized        |        |    |
|         |     |                 | 0x01    | hp p          | erformance opt.       |        |    |

## Register (0x43) GYR\_RANGE

DESCRIPTION: Defines the Gyroscope angular rate measurement range

RESET: 0x00

| Address | Bit | Name      | Descrip | tion                             |                               | Reset | Access |
|---------|-----|-----------|---------|----------------------------------|-------------------------------|-------|--------|
| 0x43    |     | GYR_RANGE |         |                                  |                               | 0x00  |        |
|         | 20  | gyr_range |         | e, Resolution:<br>ta and DATA re | applies to filtered egisters. | 0x0   | RW     |
|         |     |           | Value   | Name                             | Description                   |       |        |
|         |     |           | 0x00    | range_2000                       | +/-2000dps, 16.4<br>LSB/dps   |       |        |
|         |     |           | 0x01    | range_1000                       | +/-1000dps, 32.8<br>LSB/dps   |       |        |
|         |     |           | 0x02    | range_500                        | +/-500dps, 65.6<br>LSB/dps    |       |        |
|         |     |           | 0x03    | range_250                        | +/-250dps, 131.2<br>LSB/dps   |       |        |
|         |     |           | 0x04    | range_125                        | +/-125dps, 262.4<br>LSB/dps   |       |        |
|         | 3   | ois_range |         | e, Resolution:<br>ta and OIS dat | 0x0                           | RW    |        |
|         |     |           | Value   | Name                             | Description                   |       |        |
|         |     |           | 0x00    | range_250                        | +/-250dps, 131.2<br>LSB/dps   |       |        |
|         |     |           | 0x01    | range_2000                       | +/-2000dps, 16.4<br>LSB/dps   |       |        |

# Register (0x44) AUX\_CONF

DESCRIPTION: Sets the output data rate of the Auxiliary sensor interface

RESET: 0x46

| Address | Bit | Name       | Descrip                                                    | tion                                                           |                                       | Reset       | Access |
|---------|-----|------------|------------------------------------------------------------|----------------------------------------------------------------|---------------------------------------|-------------|--------|
| 0x44    |     | AUX_CONF   |                                                            |                                                                |                                       | 0x46        |        |
| 0×44    | 30  | aux_odr    | attached<br>is indepe<br>the sens<br>addition<br>configure | to the Auxil<br>endent of the<br>or. The outp<br>to setting th | Description Reserved 25/32 25/16 25/8 | 0x46<br>0x6 | RW     |
|         |     |            | 0x0e<br>0x0f                                               | odr 12k8                                                       | Reserved                              |             |        |
|         | 74  | aux offset |                                                            | _                                                              | t in units of 2.5 ms. If set to       | 0x4         | RW     |
|         | 74  | aux_onset  | zero, the                                                  |                                                                | aximum, i.e. after readout a          | 0.4         | 1100   |

## Register (0x45) FIFO\_DOWNS

DESCRIPTION: Configure Gyroscope and Accelerometer downsampling rates for FIFO

RESET: 0x88

DEFINITION (Go to register map):

| Address | Bit | Name               | Description                                                                                                                                      | Reset | Access |
|---------|-----|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|
| 0x45    |     | FIFO_DOWNS         |                                                                                                                                                  | 0x88  |        |
|         | 20  | gyr_fifo_downs     | Downsampling for Gyroscope (2**downs_gyro)                                                                                                       | 0x0   | RW     |
|         | 3   | gyr_fifo_filt_data | selects filtered or unfiltered Gyroscope data for fifo  Value Name Description 0x00 unfiltered Unfiltered data 0x01 filtered Filtered data       | 0x1   | RW     |
|         | 64  | acc_fifo_downs     | Downsampling for Accelerometer (2**downs_accel)                                                                                                  | 0x0   | RW     |
|         | 7   | acc_fifo_filt_data | selects filtered or unfiltered Accelerometer data for fifo  Value Name Description  0x00 unfiltered Unfiltered data  0x01 filtered Filtered data | 0x1   | RW     |

Register (0x46) FIFO\_WTM\_0

DESCRIPTION: FIFO Watermark level LSB

RESET: 0x00

| Addres | Bit    | Name                    | Description                                                                                | Rese | Acces |
|--------|--------|-------------------------|--------------------------------------------------------------------------------------------|------|-------|
| S      |        |                         |                                                                                            | t    | S     |
| 0x46   |        | FIFO_WTM_0              |                                                                                            | 0x00 |       |
|        | 7<br>0 | fifo_water_mark_7<br>_0 | Trigger an interrupt when FIFO contains fifo_water_mark_7_0+fifo_water_mark_12_8*256 bytes | 0x0  | RW    |

Register (0x47) FIFO\_WTM\_1

DESCRIPTION: FIFO Watermark level MSB and frame content configuration

RESET: 0x02

DEFINITION (Go to register map):

| Addres | Bit | Name              | Description                             | Rese | Acces |
|--------|-----|-------------------|-----------------------------------------|------|-------|
| S      |     |                   |                                         | t    | S     |
| 0x47   |     | FIFO_WTM_1        |                                         | 0x02 |       |
|        | 4   | fifo_water_mark_1 | Trigger an interrupt when FIFO contains | 0x2  | RW    |
|        | 0   | 2_8               | fifo_water_mark_7_0+fifo_water_mark_12  |      |       |
|        |     |                   | _8*256 bytes                            |      |       |

Register (0x48) FIFO\_CONFIG\_0

DESCRIPTION: FIFO frame content configuration

RESET: 0x02

| Address | Bit | Name              | Descrip                                                  | tion    |                                       | Reset | Access |
|---------|-----|-------------------|----------------------------------------------------------|---------|---------------------------------------|-------|--------|
| 0x48    |     | FIFO_CONFIG_0     |                                                          |         |                                       | 0x02  |        |
|         | 0   | fifo_stop_on_full | Stop writing samples into FIFO when FIFO is full.        |         |                                       | 0x0   | RW     |
|         |     |                   | Value                                                    | Name    | Description                           |       |        |
|         |     |                   | 0x00                                                     | disable | do not stop writing to FIFO when full |       |        |
|         |     |                   | 0x01                                                     | enable  | Stop writing into FIFO when full.     |       |        |
|         | 1   | fifo_time_en      | Return sensortime frame after the last valid data frame. |         |                                       | 0x1   | RW     |
|         |     |                   | Value                                                    | Name    | Description                           |       |        |
|         |     |                   | 0x00                                                     | disable | do not return<br>sensortime frame     |       |        |
|         |     |                   | 0x01                                                     | enable  | return sensortime frame               |       |        |

## Register (0x49) FIFO\_CONFIG\_1

DESCRIPTION: FIFO frame content configuration

RESET: 0x10

| Address | Bit | Name               | Descrip                  | tion            |                                        | Reset | Access |
|---------|-----|--------------------|--------------------------|-----------------|----------------------------------------|-------|--------|
| 0x49    |     | FIFO_CONFIG_1      |                          |                 |                                        | 0x10  |        |
|         | 10  | fifo_tag_int1_en   | FIFO int                 | errupt 1 ta     | g enable                               | 0x0   | RW     |
|         |     |                    | Value                    | Name            | Description                            |       |        |
|         |     |                    | 0x00                     | int_edge        | ~                                      |       |        |
|         |     |                    | 0.01                     | int lovel       | edge of int pin                        |       |        |
|         |     |                    | 0x01                     | int_level       | enable tag on level value of int pin   |       |        |
|         |     |                    | 0x02                     | acc_sat         | enable tag on                          |       |        |
|         |     |                    |                          | _               | saturation of                          |       |        |
|         |     |                    |                          |                 | accelerometer data                     |       |        |
|         |     |                    | 0x03                     | gyr_sat         | enable tag on                          |       |        |
|         |     |                    |                          |                 | saturation of gyroscope data           |       |        |
|         | 32  | fifo_tag_int2_en   | FIFO int                 | errupt 2 ta     |                                        | 0x0   | RW     |
|         | 02  | 1110_tag_111t2_c11 | Value                    | Name            | <b>Description</b>                     | OXO   | 1100   |
|         |     |                    | 0x00                     | int_edge        | •                                      |       |        |
|         |     |                    |                          |                 | edge of int pin                        |       |        |
|         |     |                    | 0x01                     | int_level       | enable tag on level                    |       |        |
|         |     |                    | 0.00                     | 222 224         | value of int pin                       |       |        |
|         |     |                    | 0x02                     | acc_sat         | enable tag on saturation of            |       |        |
|         |     |                    |                          |                 | accelerometer data                     |       |        |
|         |     |                    | 0x03                     | gyr_sat         | enable tag on                          |       |        |
|         |     |                    |                          |                 | saturation of                          |       |        |
|         |     |                    |                          |                 | gyroscope data                         |       |        |
|         | 4   | fifo_header_en     | FIFO frame header enable |                 |                                        | 0x1   | RW     |
|         |     |                    | Value<br>0x00            | Name<br>disable | <b>Description</b> no header is stored |       |        |
|         |     |                    | 0,00                     | disable         | (output data rate of                   |       |        |
|         |     |                    |                          |                 | all enabled sensors                    |       |        |
|         |     |                    |                          |                 | need to be identical)                  |       |        |
|         |     |                    | 0x01                     | enable          | header is stored                       |       |        |
|         | 5   | fifo_aux_en        |                          | ıxiliary ser    | nsor data in FIFO (all 3               | 0x0   | RW     |
|         |     |                    | axes) Value              | Name            | Description                            |       |        |
|         |     |                    | 0x00                     | disable         | no Auxiliary sensor                    |       |        |
|         |     |                    |                          |                 | data is stored                         |       |        |
|         |     |                    | 0x01                     | enable          | Auxiliary sensor data                  |       |        |
|         |     |                    |                          |                 | is stored                              |       |        |
|         |     |                    |                          |                 |                                        |       |        |

| 6 | fifo_acc_en | Store Acaxes) | celerome  | ter data in FIFO (all 3         | 0x0 | RW |
|---|-------------|---------------|-----------|---------------------------------|-----|----|
|   |             | Value         | Name      | Description                     |     |    |
|   |             | 0x00          | disable   | no Accelerometer data is stored |     |    |
|   |             | 0x01          | enable    | Accelerometer data              |     |    |
|   |             |               |           | is stored                       |     |    |
| 7 | fifo_gyr_en | Store Gy      | roscope ( | data in FIFO (all 3 axes)       | 0x0 | RW |
|   |             | Value         | Name      | Description                     |     |    |
|   |             | 0x00          | disable   | no Gyroscope data is stored     |     |    |
|   |             | 0x01          | enable    | Gyroscope data is stored        |     |    |

#### Register (0x4A) SATURATION

DESCRIPTION: Contains the information if one of the raw data samples used to generate current filtered data sample has been saturated (reached 0x8001 or 0x7FFF). The register is updated synchronous to the corresponding data registers in DATA\_0..19.

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name       | Description                          | Reset | Access |
|---------|-----|------------|--------------------------------------|-------|--------|
| 0x4A    |     | SATURATION |                                      | 0x00  |        |
|         | 0   | acc_x      | ACC X-axis raw data saturation flag. | 0x0   | R      |
|         | 1   | acc_y      | ACC Y-axis raw data saturation flag. | 0x0   | R      |
|         | 2   | acc_z      | ACC Z-axis raw data saturation flag. | 0x0   | R      |
|         | 3   | gyr_x      | GYR X-axis raw data saturation flag. | 0x0   | R      |
|         | 4   | gyr_y      | GYR Y-axis raw data saturation flag. | 0x0   | R      |
|         | 5   | gyr_z      | GYR Z-axis raw data saturation flag. | 0x0   | R      |

Register (0x4B) AUX\_DEV\_ID

DESCRIPTION: Auxiliary interface device\_id

RESET: 0x20

| Address | Bit | Name            | Description                            | Reset | Access |
|---------|-----|-----------------|----------------------------------------|-------|--------|
| 0x4B    |     | AUX_DEV_ID      |                                        | 0x20  |        |
|         | 71  | i2c_device_addr | I2C device address of Auxiliary sensor | 0x10  | RW     |

## Register (0x4C) AUX\_IF\_CONF

DESCRIPTION: Auxiliary interface configuration register

RESET: 0x83

DEFINITION (Go to register map):

| Address | Bit | Name             | Description                                                                                                                                                                                                                                                                          | Reset | Access |
|---------|-----|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|
| 0x4C    |     | AUX_IF_CONF      |                                                                                                                                                                                                                                                                                      | 0x83  |        |
|         | 10  | aux_rd_burst     | Burst data length (1,2,6,8 byte)  Value Name Description  0x00 BL1 Burst length 1  0x01 BL2 Burst length 2  0x02 BL6 Burst length 6  0x03 BL8 Burst length 8                                                                                                                         | 0x3   | RW     |
|         | 32  | man_rd_burst     | Manual burst data length (1,2,6,8 byte)  Value Name Description  0x00 BL1 Burst length 1  0x01 BL2 Burst length 2  0x02 BL6 Burst length 6  0x03 BL8 Burst length 8                                                                                                                  | 0x0   | RW     |
|         | 6   | aux_fcu_write_en | enables FCU write command on AUX IF for auxiliary sensors that need a trigger.                                                                                                                                                                                                       | 0x0   | RW     |
|         | 7   | aux_manual_en    | switches auxiliary interface between automatic and manual mode. In manual mode all read and write operations on auxiliary interface must be triggered manually; in automatic mode (aux_manual_en = "0") FCU triggers read and write operations periodically (as programmed by user). | 0x1   | RW     |

# Register (0x4D) AUX\_RD\_ADDR

DESCRIPTION: Auxiliary interface read address

RESET: 0x42

| Address | Bit | Name        | Description                                                     | Reset | Access |
|---------|-----|-------------|-----------------------------------------------------------------|-------|--------|
| 0x4D    |     | AUX_RD_ADDR |                                                                 | 0x42  |        |
|         | 70  | read_addr   | Address to read. In manual mode it triggers the read operation. | 0x42  | RW     |

#### Register (0x4E) AUX\_WR\_ADDR

DESCRIPTION: Auxiliary interface write address

RESET: 0x4C

DEFINITION (Go to register map):

| Address | Bit | Name        | Description                                                       | Reset | Access |
|---------|-----|-------------|-------------------------------------------------------------------|-------|--------|
| 0x4E    |     | AUX_WR_ADDR |                                                                   | 0x4C  |        |
|         | 70  | write_addr  | Address to write. In manual mode it triggers the write operation. | 0x4C  | RW     |

#### Register (0x4F) AUX\_WR\_DATA

DESCRIPTION: Auxiliary interface write data

RESET: 0x02

DEFINITION (Go to register map):

| Address | Bit | Name        | Description   | Reset | Access |
|---------|-----|-------------|---------------|-------|--------|
| 0x4F    |     | AUX_WR_DATA |               | 0x02  |        |
|         | 70  | write_data  | Data to write | 0x2   | RW     |

## Register (0x52) ERR\_REG\_MSK

DESCRIPTION: Defines which error flag will trigger the error interrupt once enabled

'1' - use to generate the error interrupt '0' - do not use to generate error interrupt

RESET: 0x00

| Address | Bit | Name         | Description                                              | Reset | Access |
|---------|-----|--------------|----------------------------------------------------------|-------|--------|
| 0x52    |     | ERR_REG_MSK  |                                                          | 0x00  |        |
|         | 0   | fatal_err    | Use fatal error to generate the error interrupt.         | 0x0   | RW     |
|         | 41  | internal_err | Use internal error to generate the error interrupt       | 0x0   | RW     |
|         | 6   | fifo_err     | Use fifo error to generate the error interrupt.          | 0x0   | RW     |
|         | 7   | aux_err      | Use aux interface error to generate the error interrupt. | 0x0   | RW     |

# Register (0x53) INT1\_IO\_CTRL

DESCRIPTION: Configure the electrical behavior of the interrupt pin INT1

RESET: 0x00

| Address | Bit | Name         | Descrip                  | tion                                  |                    |                                                   | Reset | Access |
|---------|-----|--------------|--------------------------|---------------------------------------|--------------------|---------------------------------------------------|-------|--------|
| 0x53    |     | INT1_IO_CTRL |                          |                                       |                    |                                                   | 0x00  |        |
|         | 1   | lvi          | Value 0x00 0x01          | _                                     | ow                 | Description active low active high                | 0x0   | RW     |
|         | 2   | od           | Value 0x00 0x01          | e behavi<br>Name<br>push_po<br>open_d | ull                | •                                                 | 0x0   | RW     |
|         | 3   | output_en    | Output e Value 0x00 0x01 | nable for<br>Name<br>off<br>on        | <b>Des</b><br>Outp | L pin<br>cription<br>out disabled<br>out enabled  | 0x0   | RW     |
|         | 4   | input_en     | Value 0x00 0x01          | able for II<br>Name<br>off<br>on      | <b>Des</b><br>Inpu | oin<br><b>cription</b><br>t disabled<br>t enabled | 0x0   | RW     |

Register (0x54) INT2\_IO\_CTRL

DESCRIPTION: Configure the electrical behavior of the interrupt pin INT2

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name         | Description                                                                                                   | Reset | Access |
|---------|-----|--------------|---------------------------------------------------------------------------------------------------------------|-------|--------|
| 0x54    |     | INT2_IO_CTRL |                                                                                                               | 0x00  |        |
|         | 1   | lvl          | Configure level of INT2 pin  Value Name Description  0x00 active_low active low  0x01 active_high active high | 0x0   | RW     |
|         | 2   | od           | Configure behaviour of INT2 pin  Value Name Description  0x00 push_pull push-pull  0x01 open_drain open drain | 0x0   | RW     |
|         | 3   | output_en    | Output enable for INT2 pin  Value Name Description  0x00 off Output disabled  0x01 on Output enabled          | 0x0   | RW     |
|         | 4   | input_en     | Input enable for INT2 pin  Value Name Description  0x00 off Input disabled  0x01 on Input enabled             | 0x0   | RW     |

Register (0x55) INT\_LATCH

DESCRIPTION: Configure interrupt modes

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name      | Descrip | tion           |                   | Reset | Access |
|---------|-----|-----------|---------|----------------|-------------------|-------|--------|
| 0x55    |     | INT_LATCH |         |                |                   | 0x00  |        |
|         | 0   | int_latch | Latched | /non-latched i | nterrupt modes    | 0x0   | RW     |
|         |     |           | Value   | Name           | Description       |       |        |
|         |     |           | 0x00    | none           | non latched       |       |        |
|         |     |           | 0x01    | permanent      | permanent latched |       |        |

Register (0x56) INT1\_MAP\_FEAT

**DESCRIPTION: Reserved** 

RESET: 0x00

| Address | Bit | Name          | Description | Reset | Access |
|---------|-----|---------------|-------------|-------|--------|
| 0x56    |     | INT1_MAP_FEAT |             | 0x00  |        |
|         | 70  | reserved      | Reserved    | 0x0   | RW     |

Register (0x57) INT2\_MAP\_FEAT

**DESCRIPTION: Reserved** 

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit         | Name          | Description | Reset | Access |
|---------|-------------|---------------|-------------|-------|--------|
| 0x57    |             | INT2_MAP_FEAT |             | 0x00  |        |
|         | 70 reserved |               | Reserved    | 0x0   | RW     |

Register (0x58) INT\_MAP\_DATA

DESCRIPTION: Data Interrupt mapping for both INT pins

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name         | Description                             | Reset | Access |
|---------|-----|--------------|-----------------------------------------|-------|--------|
| 0x58    |     | INT_MAP_DATA |                                         | 0x00  |        |
|         | 0   | ffull_int1   | FIFO Full interrupt mapped to INT1      | 0x0   | RW     |
|         | 1   | fwm_int1     | FIFO Watermark interrupt mapped to INT1 | 0x0   | RW     |
|         | 2   | drdy_int1    | Data Ready interrupt mapped to INT1     | 0x0   | RW     |
|         | 3   | err_int1     | Error interrupt mapped to INT1          | 0x0   | RW     |
|         | 4   | ffull_int2   | FIFO Full interrupt mapped to INT2      | 0x0   | RW     |
|         | 5   | fwm_int2     | FIFO Watermark interrupt mapped to INT2 | 0x0   | RW     |
|         | 6   | drdy_int2    | Data Ready interrupt mapped to INT2     | 0x0   | RW     |
|         | 7   | err_int2     | Error interrupt mapped to INT2          | 0x0   | RW     |

Register (0x59) INIT\_CTRL

**DESCRIPTION: Start initialization** 

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name      | Description          | Reset | Access |
|---------|-----|-----------|----------------------|-------|--------|
| 0x59    |     | INIT_CTRL |                      | 0x00  |        |
|         | 70  | init_ctrl | Start initialization | 0x0   | RW     |

init\_ctrl: Commands to start initialization

| init_ctrl |                         |                                                         |
|-----------|-------------------------|---------------------------------------------------------|
| 0x00      | Load configuration file | Enable the mode for accept configuration file           |
| 0x01      | Start initialization    | Enable sensor features after loading configuration file |

*Note:* The commands should not been used more than once after POR or soft-reset, and the process of start initialization described in Chapter 2 should be followed.

#### Register (0x5B) INIT ADDR 0

DESCRIPTION: Base address of the initialization data. Increment by burst write length in bytes/2 after each burst write operation. Please ignore, if your host supports to load the initialization data in a single 8kB burst write operation.

RESET: 0x00

DEFINITION (Go to register map):

| Δ | Address | Bit | Name        | Description                         | Reset | Access |
|---|---------|-----|-------------|-------------------------------------|-------|--------|
| 0 | x5B     |     | INIT_ADDR_0 |                                     | 0x00  |        |
|   |         | 30  | base_0_3    | Bits 0 to 3 of the base address for | 0x0   | RW     |
|   |         |     |             | initialization data.                |       |        |

#### Register (0x5C) INIT\_ADDR\_1

DESCRIPTION: Base address of the initialization data. Increment by burst write length in bytes/2 after each burst write operation. Please ignore, if your host supports to load the initialization data in a single 8kB burst write operation.

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name        | Description                          | Reset | Access |
|---------|-----|-------------|--------------------------------------|-------|--------|
| 0x5C    |     | INIT_ADDR_1 |                                      | 0x00  |        |
|         | 70  | base_11_4   | Bits 4 to 11 of the base address for | 0x0   | RW     |
|         |     |             | initialization data.                 |       |        |

Register (0x5E) INIT\_DATA

**DESCRIPTION: Initialization register** 

RESET: 0x00

| Address | Bit | Name      | Description                      | Reset | Access |
|---------|-----|-----------|----------------------------------|-------|--------|
| 0x5E    |     | INIT_DATA |                                  | 0x00  |        |
|         | 70  | data      | Register for initialization data | 0x0   | RW     |

#### Register (0x5F) INTERNAL\_ERROR

DESCRIPTION: Internal error flags. Value of all reserved bits should be ignored.

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name              | Description                                                      | Reset | Access |
|---------|-----|-------------------|------------------------------------------------------------------|-------|--------|
| 0x5F    |     | INTERNAL_ERROR    |                                                                  | 0x00  |        |
|         | 1   | int_err_1         | Internal error flag - long processing time, processing halted    | 0x0   | R      |
|         | 2   | int_err_2         | Internal error flag - fatal error, processing halted             | 0x0   | R      |
|         | 4   | feat_eng_disabled | Feature engine has been disabled by host during sensor operation | 0x0   | R      |

# Register (0x68) AUX\_IF\_TRIM

DESCRIPTION: Auxiliary interface trim register (NVM backed)

RESET: 0x01

DEFINITION (Go to register map):

| Address | Bit | Name        | Descrip  | tion             |             | Reset | Access |
|---------|-----|-------------|----------|------------------|-------------|-------|--------|
| 0x68    |     | AUX_IF_TRIM |          |                  |             | 0x01  |        |
|         | 10  | asda_pupsel | Pullup c | onfiguration for | ASDA        | 0x1   | RW     |
|         |     |             | Value    | Name             | Description |       |        |
|         |     |             | 0x00     | pup_res_off      | Pullup off  |       |        |
|         |     |             | 0x01     | pup_res_40k      | Pullup 40k  |       |        |
|         |     |             | 0x02     | pup_res_10k      | Pullup 10k  |       |        |
|         |     |             | 0x03     | pup_res_2k       | Pullup 2k   |       |        |

#### Register (0x6A) NVM CONF

**DESCRIPTION: NVM Configuration** 

RESET: 0x00

| Address | Bit | Name        | Descripti | ion                                         |                                             | Reset | Access |
|---------|-----|-------------|-----------|---------------------------------------------|---------------------------------------------|-------|--------|
| 0x6A    |     | NVM_CONF    |           |                                             |                                             | 0x00  |        |
|         | 1   | nvm_prog_en | 0x00      | VM prog<br><b>Name</b><br>disable<br>enable | ramming. <b>Description</b> disable  enable | 0x0   | RW     |

Register (0x6B) IF\_CONF

**DESCRIPTION: Serial interface settings** 

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name     | Description                                                                                                                               | Reset | Access |
|---------|-----|----------|-------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|
| 0x6B    |     | IF_CONF  |                                                                                                                                           | 0x00  |        |
|         | 0   | spi3     | Configure SPI Interface Mode for primary interface  Value Name Description  0x00 spi4 SPI 4-wire mode  0x01 spi3 SPI 3-wire mode          | 0x0   | RW     |
|         | 1   | spi3_ois | Configure SPI Interface Mode for OIS interface (if enabled)  Value Name Description  0x00 spi4 SPI 4-wire mode  0x01 spi3 SPI 3-wire mode | 0x0   | RW     |
|         | 4   | ois_en   | Interface configuration - OIS enable bit. It has lower priority than aux_en.                                                              | 0x0   | RW     |
|         | 5   | aux_en   | Interface configuration - AUX enable bit. It has higher priority than ois_en.                                                             | 0x0   | RW     |

# Register (0x6C) DRV

DESCRIPTION: Drive strength control register (NVM backed)

RESET: 0xFF

| Address | Bit | Name          | Description                        | Reset | Access |
|---------|-----|---------------|------------------------------------|-------|--------|
| 0x6C    |     | DRV           |                                    | 0xFF  |        |
|         | 20  | io_pad_drv1   | Output pad drive strength setting. | 0x7   | RW     |
|         | 3   | io_pad_i2c_b1 | Output pad drive strength setting. | 0x1   | RW     |
|         |     | io_pad_drv2   | Output pad drive strength setting. | 0x7   | RW     |
|         | 7   | io_pad_i2c_b2 | Output pad drive strength setting. | 0x1   | RW     |

#### Register (0x6D) ACC\_SELF\_TEST

DESCRIPTION: Settings for the accelerometer self-test configuration and trigger

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name               | Description                                                                                        | Reset | Access |
|---------|-----|--------------------|----------------------------------------------------------------------------------------------------|-------|--------|
| 0x6D    |     | ACC_SELF_TEST      |                                                                                                    | 0x00  |        |
|         | 0   | acc_self_test_en   | Value Name Description  0x00 disabled disabled  0x01 enabled enabled                               | 0x0   | RW     |
|         | 2   | acc_self_test_sign | select sign of self-test excitation asValueNameDescription0x00negativenegative0x01positivepositive | 0x0   | RW     |
|         | 3   | acc_self_test_amp  | select amplitude of the selftest deflection:ValueNameDescription0x00lowlow0x01highhigh             | 0x0   | RW     |

# Register (0x6E) GYR\_SELF\_TEST\_AXES

DESCRIPTION: Settings for the gyroscope AXES self-test configuration and trigger

RESET: 0x00

| Address | Bit | Name               | Description                                             | Reset | Access |
|---------|-----|--------------------|---------------------------------------------------------|-------|--------|
| 0x6E    |     | GYR_SELF_TEST_AXES |                                                         | 0x00  |        |
|         | 0   | gyr_st_axes_done   | STATUS: functional test of detection channels finished. | 0x0   | R      |
|         | 1   | gyr_axis_x_ok      | status of gyro X-axis self test                         | 0x0   | R      |
|         | 2   | gyr_axis_y_ok      | status of gyro Y-axis self test                         | 0x0   | R      |
|         | 3   | gyr_axis_z_ok      | status of gyro Z-axis self test                         | 0x0   | R      |

Register (0x70) NV\_CONF

DESCRIPTION: NVM backed configuration bits.

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name        | Description                                                                                                                                                                   | Reset | Access |
|---------|-----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|
| 0x70    |     | NV_CONF     |                                                                                                                                                                               | 0x00  |        |
|         | 0   | spi_en      | disable the I2C and enable SPI for the primary interface, when it is in autoconfig mode  Value Name Description  0x00 disabled I2C enabled  0x01 enabled I2C disabled         | 0x0   | RW     |
|         | 1   | i2c_wdt_sel | Select timer period for I2C Watchdog  Value Name Description  0x00 short I2C watchdog timeout after 1.25 ms  0x01 long I2C watchdog timeout after 40 ms                       | 0x0   | RW     |
|         | 2   | i2c_wdt_en  | I2C Watchdog at the SDA pin in I2C interface mode  Value Name Description  0x00 Disable Disable I2C watchdog  0x01 Enable Enable I2C watchdog                                 | 0x0   | RW     |
|         | 3   | acc_off_en  | Add the offset defined in the off_acc_[xyz] OFFSET register to filtered and unfiltered Accelerometer data  Value Name Description 0x00 disabled Disabled 0x01 enabled Enabled | 0x0   | RW     |

Register (0x71) OFFSET\_0

DESCRIPTION: Offset compensation for Accelerometer X-axis (NVM backed)

RESET: 0x00

| Address | Bit | Name      | Description                                 | Reset | Access |
|---------|-----|-----------|---------------------------------------------|-------|--------|
| 0x71    |     | OFFSET_0  |                                             | 0x00  |        |
|         | 70  | off_acc_x | Accelerometer offset compensation (X-axis). | 0x0   | RW     |

#### Register (0x72) OFFSET 1

DESCRIPTION: Offset compensation for Accelerometer Y-axis (NVM backed)

RESET: 0x00

DEFINITION (Go to register map):

| A | Address | Bit | Name      | Description                                 | Reset | Access |
|---|---------|-----|-----------|---------------------------------------------|-------|--------|
| C | )x72    |     | OFFSET_1  |                                             | 0x00  |        |
|   |         | 70  | off acc y | Accelerometer offset compensation (Y-axis). | 0x0   | RW     |

#### Register (0x73) OFFSET 2

DESCRIPTION: Offset compensation for Accelerometer Z-axis (NVM backed)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name      | Description                                 | Reset | Access |
|---------|-----|-----------|---------------------------------------------|-------|--------|
| 0x73    |     | OFFSET_2  |                                             | 0x00  |        |
|         | 70  | off_acc_z | Accelerometer offset compensation (Z-axis). | 0x0   | RW     |

#### Register (0x74) OFFSET 3

DESCRIPTION: Offset compensation for Gyroscope X-axis (NVM backed)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name              | Description                             | Reset | Access |
|---------|-----|-------------------|-----------------------------------------|-------|--------|
| 0x74    |     | OFFSET_3          |                                         | 0x00  |        |
|         | 70  | gyr_usr_off_x_7_0 | Gyroscope offset compensation (X-axis). | 0x0   | RW     |

#### Register (0x75) OFFSET 4

DESCRIPTION: Offset compensation for Gyroscope Y-axis (NVM backed)

RESET: 0x00

| Address | Bit | Name              | Description                             | Reset | Access |
|---------|-----|-------------------|-----------------------------------------|-------|--------|
| 0x75    |     | OFFSET_4          |                                         | 0x00  |        |
|         | 70  | gyr_usr_off_y_7_0 | Gyroscope offset compensation (Y-axis). | 0x0   | RW     |

## Register (0x76) OFFSET\_5

DESCRIPTION: Offset compensation for Gyroscope Z-axis (NVM backed)

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name              | Description                             | Reset | Access |
|---------|-----|-------------------|-----------------------------------------|-------|--------|
| 0x76    |     | OFFSET_5          |                                         | 0x00  |        |
|         | 70  | gyr usr off z 7 0 | Gyroscope offset compensation (Z-axis). | 0x0   | RW     |

## Register (0x77) OFFSET\_6

DESCRIPTION: Offset compensation (MSBs gyroscope, enables) (NVM backed)

RESET: 0x00

| Address | Bit | Name              | Description                                                                                                                                                                     | Reset | Access |
|---------|-----|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|
| 0x77    |     | OFFSET_6          |                                                                                                                                                                                 | 0x00  |        |
|         | 10  | gyr_usr_off_x_9_8 | Gyroscope offset compensation (X-axis).                                                                                                                                         | 0x0   | RW     |
|         | 32  | gyr_usr_off_y_9_8 | Gyroscope offset compensation (Y-axis).                                                                                                                                         | 0x0   | RW     |
|         | 54  | gyr_usr_off_z_9_8 | Gyroscope offset compensation (Z-axis).                                                                                                                                         | 0x0   | RW     |
|         | 6   | gyr_off_en        | Add the offset defined in the gyr_usr_off_[xyz] OFFSET register to filtered and unfiltered Gyroscope data  Value Name Description  0x00 disabled Disabled  0x01 enabled Enabled | 0×0   | RW     |
|         | 7   | gyr_gain_en       | Compensate the gain as described in section "Sensitivity Error Compensation".  Value Name Description  0x00 disabled Disabled  0x01 enabled Enabled                             | 0x0   | RW     |

Register (0x7C) PWR\_CONF

DESCRIPTION: Power mode configuration register

RESET: 0x03

| Address | Bit | Name              | Descrip                   | tion                           |                                                                                                                                            | Reset | Access |
|---------|-----|-------------------|---------------------------|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|
| 0x7C    |     | PWR_CONF          |                           |                                |                                                                                                                                            | 0x03  |        |
|         | 0   | adv_power_save    | Advance<br>Value<br>0x00  | Name                           | Description Advanced power save disabled.                                                                                                  | 0x1   | RW     |
|         |     |                   | 0x01                      | aps_on                         | Advanced power mode enabled.                                                                                                               |       |        |
|         | 1   | fifo_self_wake_up | Value<br>0x00<br>0x01     | ad disable Name fsw_off fsw_on | d in low power mode  Description  FIFO read disabled in low power mode  FIFO read enabled in low power mode after  FIFO interrupt is fired | 0x1   | RW     |
|         | 2   | fup_en            | Fast pov<br>Value<br>0x00 | ver up ena Name fup_off fup_on | able  Description  Fast power up  disabled  Fast power up  enabled                                                                         | 0x0   | RW     |

Register (0x7D) PWR\_CTRL

DESCRIPTION: Power mode control register

RESET: 0x00

DEFINITION (Go to register map):

| Address | Bit | Name     | Descrip                | tion                        | Reset                                                                     | Access |    |
|---------|-----|----------|------------------------|-----------------------------|---------------------------------------------------------------------------|--------|----|
| 0x7D    |     | PWR_CTRL |                        |                             |                                                                           | 0x00   |    |
|         | 0   | aux_en   |                        |                             |                                                                           | 0x0    | RW |
|         |     |          | Value<br>0x00          | Name<br>aux_off             | <b>Description</b> Disables the Auxiliary sensor.                         |        |    |
|         |     |          | 0x01                   | aux_on                      | Enables the Auxiliary sensor.                                             |        |    |
|         | 1   | gyr_en   | <b>Value</b> 0x00 0x01 | Name<br>gyr_off<br>gyr_on   | <b>Description</b> Disables the Gyroscope. Enables the Gyroscope.         | 0x0    | RW |
|         | 2   | acc_en   | <b>Value</b> 0x00 0x01 | Name<br>acc_off<br>acc_on   | <b>Description</b> Disables the Accelerometer. Enables the Accelerometer. | 0x0    | RW |
|         | 3   | temp_en  | <b>Value</b> 0x00 0x01 | Name<br>temp_off<br>temp_on | sensor.                                                                   | 0x0    | RW |

Register (0x7E) CMD

**DESCRIPTION: Command Register** 

RESET: 0x00

| Address | Bit | Name | Descrip                                                                     | tion       |                                                                                            | Reset | Access |
|---------|-----|------|-----------------------------------------------------------------------------|------------|--------------------------------------------------------------------------------------------|-------|--------|
| 0x7E    |     | CMD  |                                                                             |            |                                                                                            |       |        |
|         | 70  | cmd  | Available commands (Note: Register will always return 0x00 as read result): |            |                                                                                            |       | W      |
|         |     |      | Value                                                                       | Name       | Description                                                                                |       |        |
|         |     |      | 0xa0                                                                        | nvm_prog   | Writes the NVM backed registers into NVM                                                   |       |        |
|         |     |      | 0xb0                                                                        | fifo_flush | Clears FIFO content                                                                        |       |        |
|         |     |      | 0xb6                                                                        | softreset  | Triggers a reset, all user configuration settings are overwritten with their default state |       |        |

# 5. Legal disclaimer

#### 5.1. Engineering samples

Engineering Samples are marked with an asterisk (\*), (E) or (e). Samples may vary from the valid technical specifications of the product series contained in this data sheet. They are therefore not intended or fit for resale to third parties or for use in end products. Their sole purpose is internal client testing. The testing of an engineering sample may in no way replace the testing of a product series. Bosch Sensortec assumes no liability for the use of engineering samples. The Purchaser shall indemnify Bosch Sensortec from all claims arising from the use of engineering samples.

#### 5.2. Product use

Bosch Sensortec products are developed for the consumer goods industry. They may only be used within the parameters of this product data sheet. They are not fit for use in life-sustaining or safety-critical systems. Safety-critical systems are those for which a malfunction is expected to lead to bodily harm, death or severe property damage. In addition, they shall not be used directly or indirectly for military purposes (including but not limited to nuclear, chemical or biological proliferation of weapons or development of missile technology), nuclear power, deep sea or space applications (including but not limited to satellite technology).

Bosch Sensortec products are released on the basis of the legal and normative requirements relevant to the Bosch Sensortec product for use in the following geographical target market: BE, BG, DK, DE, EE, FI, FR, GR, IE, IT, HR, LV, LT, LU, MT, NL, AT, PL, PT, RO, SE, SK, SI, ES, CZ, HU, CY, US, CN, JP, KR, TW. If you need further information or have further requirements, please contact your local sales contact.

The resale and/or use of Bosch Sensortec products are at the purchaser's own risk and his own responsibility. The examination of fitness for the intended use is the sole responsibility of the purchaser.

The purchaser shall indemnify Bosch Sensortec from all third party claims arising from any product use not covered by the parameters of this product data sheet or not approved by Bosch Sensortec and reimburse Bosch Sensortec for all costs in connection with such claims.

The purchaser accepts the responsibility to monitor the market for the purchased products, particularly with regard to product safety, and to inform Bosch Sensortec without delay of all safety-critical incidents.

#### 5.3. Application examples and hints

With respect to any examples or hints given herein, any typical values stated herein and/or any information regarding the application of the device, Bosch Sensortec hereby disclaims any and all warranties and liabilities of any kind, including without limitation warranties of non-infringement of intellectual property rights or copyrights of any third party. The information given in this document shall in no event be regarded as a guarantee of conditions or characteristics. They are provided for illustrative purposes only and no evaluation regarding infringement of intellectual property rights or copyrights or regarding functionality, performance or error has been made.

# 6. Document History and Modification

| Rev. No | Chapter | Description of modification/changes | Date     |
|---------|---------|-------------------------------------|----------|
| 1.0     |         | Document creation                   | Feb 2021 |



#### **Bosch Sensortec GmbH**

Gerhard-Kindler-Straße 9 72770 Reutlingen / Germany

contact@bosch-sensortec.com www.bosch-sensortec.com

Modifications reserved Specifications subject to change without notice Document number: BST-BMI270-AN001-01 Revision\_1.0\_022021